<template>
  <p>通过设置 columns 属性 slots 自定义表格头及对应列单元格的插槽</p>
  <p>插槽名需要避开内置插槽 expand \ expander_default \ selection_header \ selection_checkbox \ handler_default 等名称</p>
  <MerakXTable
    :columns-by-store="JSON.parse(JSON.stringify(state.columns))"
    :columns="state.columns"
    :data="state.data"
    :pagination="false"
  >
    <template #column_name_header="{ column }">
      <div>列表头: {{ column.title }}</div>
    </template>
    <template #column_name_default="{ row }">
      <div>单元格: {{ row.name }}</div>
    </template>
  </MerakXTable>
  <slot :html="html" />
</template>

<script setup lang="ts">
import { ref, reactive } from "vue";

import MerakXTable, { MerakXTableColumn } from "../../../../../components/MerakXTable";

const html = ref(`
<template>
  <div style="height: 70vh">
    <MerakXTable
      :columns-by-store="JSON.parse(JSON.stringify(state.columns))"
      :columns="state.columns"
      :data="state.data"
      :pagination="false"
    >
      <template #column_name_header="{ column }">
        <div>列表头: {{ column.title }}</div>
      </template>
      <template #column_name_default="{ row }">
        <div>单元格: {{ row.name }}</div>
      </template>
    </MerakXTable>
  </div>
</template>

<script setup lang="ts">
import { reactive } from "vue";

import MerakXTable, { MerakXTableColumn } from "../../../../../components/MerakXTable";

const state = reactive<{
  columns: MerakXTableColumn[];
  data: any[];
}>({
  columns: [
    { field: "name", title: "Name", slots: { header: \`column_name_header\`, default: \`column_name_default\` } },
    { field: "age", title: "Age" },
    { field: "address", title: "Address" }
  ],
  data: [
    {
      id: "1",
      name: "John Brown",
      age: 32,
      address: "New York No. 1 Lake Park",
      description: "My name is John Brown, I am 32 years old, living in New York No. 1 Lake Park."
    },
    {
      id: "2",
      name: "Jim Green",
      age: 42,
      address: "London No. 1 Lake Park",
      description: "My name is Jim Green, I am 42 years old, living in London No. 1 Lake Park."
    },
    {
      id: "3",
      name: "Not Expandable",
      age: 29,
      address: "Jiangsu No. 1 Lake Park",
      description: "This not expandable"
    },
    {
      id: "4",
      name: "Joe Black",
      age: 32,
      address: "Sydney No. 1 Lake Park",
      description: "My name is Joe Black, I am 32 years old, living in Sydney No. 1 Lake Park."
    }
  ]
});
<\/script>
`);

const state = reactive<{
  columns: MerakXTableColumn[];
  data: any[];
}>({
  columns: [
    { field: "name", title: "Name", slots: { header: `column_name_header`, default: `column_name_default` } },
    { field: "age", title: "Age" },
    { field: "address", title: "Address" }
  ],
  data: [
    {
      id: "1",
      name: "John Brown",
      age: 32,
      address: "New York No. 1 Lake Park",
      description: "My name is John Brown, I am 32 years old, living in New York No. 1 Lake Park."
    },
    {
      id: "2",
      name: "Jim Green",
      age: 42,
      address: "London No. 1 Lake Park",
      description: "My name is Jim Green, I am 42 years old, living in London No. 1 Lake Park."
    },
    {
      id: "3",
      name: "Not Expandable",
      age: 29,
      address: "Jiangsu No. 1 Lake Park",
      description: "This not expandable"
    },
    {
      id: "4",
      name: "Joe Black",
      age: 32,
      address: "Sydney No. 1 Lake Park",
      description: "My name is Joe Black, I am 32 years old, living in Sydney No. 1 Lake Park."
    }
  ]
});
</script>
